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© Data processing apparatus. 

© An apparatus and method are provided for disabling the 
clocking of a processor in a battery operated computer during 
non-processing times. The clocking is disabled at the conclu- 
sion of a processing operation. The clocking can then be 
re-enabled using interrupts from any one of a plurality of 
sources, such as an I/O device or a direct memory access. 
Application programs and operating system programs running 
on the system can specify the stopping of the system clock and 
the central processor until a specified event which had been 
requested occurs, or until an optional time-out period has 
expired. In this situation, the event is defined as one that results 
in either a system interrupt from an I/O device or from a direct 
memory access operation. The stopping of the system clock is 
a two part operation wherein in the first part the stopping 
mechanism is first armed. If an interrupt is received subsequent 
to arming, then it will be processed and the arming mechanism 
will be reset. However, if an Interrupt does not occur after 
arming within a specified time period, then the system clock will 
be stopped. 
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Description 



DATA PROCESSING APPARATUS 



This invention relates to data processing appara- 
tus and a method for stopping a system clock in a 
computer, and more particularly for stopping a 5 
system clock in a battery operated computer to 
reduce power consumption. 

In the data processing environment, a large 
percentage of a centraJ processor's time is spent in 
idle loops waiting for one or more I/O devices to 10 
complete an operation or for further input to the 
processor from an operator. In a system where AC 
power is being used to provide power to the central 

processor, the time spent in idle loops is not very 

critical. However, in an operating environment 15 
wherein power is being supplied to the central 
processor from a battery, time spent in idle loops by 
the central processor needlessly wastes battery 
power. Consequently, it would be- desirable to 
prevent a central processor from performing idle 20 
loops while waiting for the completion of an 
operation by an I/O device or when waiting for 
further input to the processor from an operator. As 
small computers, especially those which are port- 
able, become more prevalent, the need to conserve 25 
battery power becomes increasingly important. 

Typically, a battery operated computer uses 

to reduce power consumption. However, in order to 
take full advantage of these CMOS circuits, the 30 
circuits need not be clocked when their usage is not 
required. As is well known, the characteristics of 
CMOS circuits provide very low standby power 
consumption when they are not being clocked. In 
order to fully realize this power saving advantage, $5 
-.application programs and the operating system 
software that are running on the data processing 
system must be able to stop the system clocks when 
the central processor is waiting for the completion of 
an I/O operation or for further operator input 40 

U. S. Patent 3,941,989 discloses one method for 
reducing power consumption in calculators wherein 
lower duty cycle power and lower duty cycle clock 
pulses are supplied during the calculator display 
mode. While the calculator is in an execute mode, 45 
continuous power and a high rate clock are supplied. 
If an execute mode is not initiated within a selected 
time interval, the duty cycle of both the power and 
the clock are lowered even further than that 
provided during the display mode. 50 . 

U. S. Patent 4,435,761 disclose a data processing 
apparatus having both a data transmitting and 
receiving unit for transferring data, and a processing 
unit for processing the data. Means are provided for 
stopping the supply of a control clock signal while 55 
the transmission of data is in progress. 

Another approach to conserving energy in data 
processing systems is shown in both U. S. Patents 
4,279.020 and 4.455.623. In^the former, when the 
central processor completes operation, it provides 60 
an output signal to a power-down sub-circuit of a 
power supply which then removes power from the 
central processor. In this manner, power is not 



supplied to the processor when it is not operating. In 
the latter, the current consumption of a micropro- 
cessor is decreased by a switch which connects it to 
a power supply only when a control signal is received 
which indicates that the microprocessor is to 
execute a program. Specifically, an electronic switch 
is used to switch to a non-conductive state unless a 
control signal is received. For software programs 
which require a greater time for execution than the 
duration of the control signal, the microprocessor 
supplies a signal to the electronic switch thereby 
keeping it in the conductive state until the software 
program has been fully executed. A similar approach 
is shown in U. S. Patent 4,203.153. 

U. S. Patent 4,409,665 discloses the conservation 
of power in a calculator having a memory utilizing 
CMOS circuits. Incorporation of two switched volt- 
ages and a single non-switched voltage enables 
power to be switched off to the calculator's logic, 
display interface and keystroke detect circuitry, 
while power is maintained to the memory. In other 
embodiments, multiple modes such as off mode, 
display only mode, process only mode, and a display 
and process mode are used to optimize power 
dissipation. The calculator powers up into the 
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time, power is supplied to the processor until 
completion of the processing. This power conserva- 
tion is effected using a first power switching means 
connected to a first circuit group and to a power 
consumption controller, and a second power switch- 
ing means connected to the power consumption 
controller and to a second circuit group. 

According to the invention an apparatus and 
method are provided for disabling the clocking of a 
central processor in a battery operated computer 
during non-processing times. Means are provided 
for disabling the clocking at the conclusion of a 
processing operation and for enabling the clocking 
of the processor using interrupts from any one of a 
plurality of sources. These interrupts include direct 
memory access (DMA) interrupts, as well as I/O 
interrupts which occur when an I/O device needs 
services. The I/O interrupts invoke short routines 
located in either ROM or in a main application 
program that are used to service an I/O device. The 
I/O devices include a display, printer, diskette drives, 
a keyboard, and communication devices such as a 
modem and a RS232 communication interface, and a 
system timer. 

A function is provided which provides application 
programs and operating system programs running 
on the computer system with a method to specify 
the stopping of system clocks and the central 
processor until a specified event which had been 
requested occurs or until an optional time-out period 
has expired. In this situation, the event is defined as 
one that results in either a system interrupt from one 
of the plurality of I/O devices or from a DMA 
operation. 

In operation, hardware which is used to stop the 
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system clocks is first armed. This arming does not in 
itself stop the clocks but rather enables them to be 
stopped at a later time. If an Interrupt is then 
received, it will be processed and the arming 
mechanism will be reset. However, if an interrupt 5 
does not occur after arming, within a specified time 
period, then the system clock will be stopped. The 
system clock will then be restarted upon the receipt 
of an Interrupt - either in the form of a direct memory 
access or from an I/O device. w 

In order that the invention may be fully understood 
a preferred embodiment thereof will now be de- 
scribed with reference to the accompanying draw- 
ings in which: 

Fig. 1 is a functional block diagram of the 75 
system according to the present invention. 

Fig. 2 is a flow chart of the overall operation of 
the system according to the present invention. 

Fig. 3 is a flow chart of a function depicting 
operation of the system as it waits for a 20 
specified event. 

Fig. 4 is a flow chart for comparing the bytes 
comprising a received event to the bytes of a 
predetermined event. 

Fig. 5 is a flow chart depicting the testing of 25 
the bits of a predetermined event with the bits 
of a received event 

Fig. 6 is a flow chart of the operation of the 
system according to the present invention just 
prior to and just after the stopping of the 30 
system clock. 

hig. 7 is a flow chart of the operation of the 
system according to the present invention as it 
awaits a keyboard interrupt. 

Fig. 8 is a flow chart of the system according 35 
to the present invention as it awaits a diskette 
interrupt. 

Referring now more particularly to the drawings, 
the overall system of the invention is shown in Fig. 1 . 
System bus 44 provides data communication among 40 
interrupt controller 12, CPU 11 through bus control 
29, sleep clock control 32, direct memory access 
controller 13, system RAM 15, system ROM 16, 
keyboard controller 17, system timer 18, diskette 
controller 19, real time clock 21, modem 22 and 45 
RS232 communication interface 23, display control- 
ler 14, printer interface 24, and expansion connector 
36. Note that there is data communication between 
keyboard controller 17 and keyboard 28, between 
diskette controller 19 and diskette drives 26 and 27, 50 
between printer interface 24 and printer 37, as well 
as between display controller 14 and display 25 and 
display RAM 34. Expansion connector 36 provides 
communication with other I/O devices not shown in 
Fig. 1. Direct memory access (DMA) controller 55 
contains both clocked and unclocked sections, i.e., 
some sections of controller 13 require continuous 
clocking while others do not. 

Sleep clock control 32 is essentially a switch 
mechanism. System clock 33 provides a clock input 60 
over line 50 to sleep clock control 32. During a 
normal clocking operation, sleep clock control 32 
passes this clocking signal over output 40 to bus 51. 
As can be seen, the clocking signal is provided to 
CPU 1 1 as well as to the remainder of the devices on 65 



bus 51. During non-clocking time periods, no 
^clocking signal is provided from output 40 of sleep 
clock control 32. Note that a clocking signal is 
provided at alt times over bus 53 to keyboard 
controller 17, system timer 18, diskette controller 19, 
modem 22, RS232 .communication interface 23. 
printer interface 24, display controller 14, and 
expansion connector 36. These devices are contin- 
ually clocked by system clock 33. It is only CPU 11, 
system RAM 15, DMA con-troller 13, and bus 
controller 29 to which the clock signal from system* 
clock 33 is turned on and off, thereby saving power. 

Interrupt controller 12 receives interrupts from 
printer interface 24, modem 22, and RS232 com- 
munication interface 23, real time clock 21 , diskette 
controller 19. system timer 18, and keyboard 
controller 17. An interrupt request is sent from 
interrupt controller 12 over line 52 to sleep clock 
control 32. When this occurs, sleep clock control 32 
provides over output 40 a clocking signal out over 
bus 51. Interrupt controller 12 also provides an 
interrupt signal as well as a non-maskable interrupt 
(NMI) signal to CPU 11. Finally, whenever a direct 
memory access request is received by DMA control- 
ler 13, it outputs over line 60 a DMA request to sleep 
clock control 32. Sleep clock control 32 then 
provides a clocking signal over output 40 onto bus 
51. This occurs whenever an I/O device requires 
direct memory access. 

Sleep clock control 32 continues to supply the 
clock over uus 5 i untii me "Wait for External Event* 
code executing in CPU 11 from ROM 16 issues an 
ARM and STOP CLOCK I/O instruction. These 
instructions cause data to travel over bus 44 to sleep 
clock control 32. Sleep clock control then stops 
clock output 40, causing the clock signal on bus 51 
to stop. This suspends execution of CPU 11 and 
other associated components. If an interrupt or DMA 
request is received after the ARM instruction has 
been issued but before or during the issuance of the 
STOP CLOCKS instruction, the sleep clock control 
32 will not honour the STOP CLOCKS instruction and 
the clock on bus 52 will continue to run causing the 
CPU 11 to continue execution after the STOP 
CLOCKS instruction. 

The general operation of the system of the 
present invention may be explained with reference 
to Fig. 2. At a time when CPU 1 1 is executing an 
application program or an I/O task, it waits for a task 
to be performed by one of the I/O devices. The 
dispatching of such a task by the operating system 
running on CPU 11 is included as an example and 
does not form a part of the present invention and will 
not be discussed further hereinafter. CPU 11 goes 
through a series of determinations. In decision block 
41 , a determination is made as to whether or not the 
communication queue is empty, i.e., whether modem 
22 or RS232 communication interface 23 require an 
operation to be performed. If either do require such 
an operation, i.e., the communication queue is not 
empty, then as shown in block 46, CPU 11 
dispatches using its operating system the communi- 
cation task which is to be performed. However, if the 
communication queue is empty, then a second 
determination is made. In this case, as shown in 
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decision block 42. a determination is made as to 
whether or not the video queue Is empty Once 
again, if it's not, then CPU 11 dispatches a video 
processing task as shown in step 47. However if the 
video queue is empty, then a determination is made 
as to whether or not the printer queue is empty, tf it 
is not, then as shown in step 48, a printer processing 
test is dispatched from CPU 11. Upon t he pi int er 
queue being empty, the queue of keyboard control- 
ler 17 is next checked as shown in step 45. Once 
again, if the queue is not empty, then CPU 11 
dispatches a keyboard processing task as shown in 
step 49. Finally, If ail of the queues which are to be 
checked are empty, signifying that CPU 11 need not 
dispatch any tasks to the I/O devices, then CPU 11 
goes into a mode where it waits for an external 
event The "Wait for External Event* routine ~is then 
entered. It will ARM sleep clock control 32 by issuing 
an ARM and STOP I/O command over bus 44 which 
causes sleep clock control 32 to stop providing a 
clock on bus 51, thus suspending processing of 
CPU 11 after the I/O instruction. CPU 11 will stay 
unclocked until an interrupt or DMA request is 
received by sleep control 32, at which point clocks 
are again provided on bus 55. This will cause CPU 11 
to resume instruction processing of the event 
determination routine. Since a wait for any event was 
requested in this case, control is returned to the top 
of the dispatched as shown in Figure 2. 

The flow chart of Fig. 3 explains the operation of 
the t system as it awaits an external event or until »n 
cptianal iimo-oui penod has expired. In the system 
of the present invention, such an external event is 
defined as one that results in either a system 
interrupt or in a DMA operation, either of which 
causes a clocking signal to be restarted to those 
non-continuously clocked devices in the system. 
The computer code used to carry out the operation 
of Fig. 3 is contained in system ROM 16. The 
particular code may be called by another program 
residing in ROM 16 or may be called by an 
application running in RAM 15. 

A wait for specific event flow is shown in Figure 3. 
As indicated in decision block 61. a determination is 
first made as to whether or not a time-out function 
has been requested. A time-out function is used only 
by certain ones of the I/O devices in the system. For 
example, diskette controller 19 requires a time-out 
because if either one of diskette drives 26 or 27 were 
to malfunction during a read or write operation, then 
CPU 11 could wait indefinitely for an event that win 
not occur due to an error. If a time-out function is 
used, then if a read or write operation is not 
completed within the allotted time-out period, then 
the CPU 11 clock is restarted by timer 18 and the 
code in ROM indicates a time-out error to the 
application program or operating system, thereby 
allowing corrective action to be taken. Conse- 
quently, if a time-out has been requested, then as 
shown in step 62, a time-out counter is set in RAM 
15 and a time-out requested flag is set to be active. If 
no time-out has been requested or the time-out 
counter and flag have been set. then a determination 
is made as to whether or not the system is waiting 
for any event to occur, or if a specific event is being 



waited for. If anyevent is being waited for by the 
system, then as shown in block 64. the sleep clock 
control 32 is armed and in block 65 sleep clock 
control 32 stops the system clocks. The CPU 

5 execution will be suspended in block 65 until an 
external event, interrupt or DMA request occurs. At 
that time, CPU 11 instruction execution is resumed 
and control passed back to the program requesting 
the wait for external event. 

W However, if a specific event within the system is 
being awaited, then two additional determinations 
must first be made. In decision block 66, a 
determination is made as to whether or not the 
■specific event being waited for will be compared with 

15 a pre-existing mask. This determination is used to 
compare the predetermined mask on a byte basis 
with the event being waited for. In other words a 
predetermined byte of data describing the occur- 
rence of a specific event, or specific events, is 

20 compared on a byte basis with the events which 
occur In the system. If this is the case, then as 
shown In step 67, the flow chart will continue to Fig. 4 
which will be explained in more detail hereinafter. 
However, if the answer to decision block 66 is no, 
25 then a determination is made in decision block 68 as 
to whether or not the predetermined event which is 
being awaited will be compared on a bit by bit basis 
with any occurring events in the system. If the 
answer to decision block 68 is yes, then as shown in 

30 S u GP 3 X - Q l ? QlC Wil ' COntinUe tO the flOW rhart 

chcv... in Fig. o. However, if the answer to decision 
block 68 is no, then an invalid request has been 
received by CPU 11 and an error is returned to the 
application program or operating system requesting 
35 the wait. Summarizing, decision block 66 determines 
whether or not any occurring events are to be 
compared on a byte basis with the predetermined 
event which is being waited for. Decision block 68 
makes a determination as to whether or not the 

40 occurring event will be compared on a bit by bit 
basis with the predetermined event upon which the 
system is waiting. The compare byte approach is 
useful when one specific event is being waited for, 
and the compare bits approach is useful when a 

45 select set of events is being waited for. 

The flow chart of Fig. 4 depicts the comparison of 
an incoming data request with a predetermined 
event mask when the two are to be compared on a 
byte basis. In step 73, the sleep clock arm control of 

50 sleep control 32 is enabled. Recall that this is the 
first part in the two part process for stopping the 
system clock 33 to the non-continuously clocked 
devices in the system. Next, in step 74, the data to 
which the event occurrence data is to be compared 

55 on the byte basis is read from the specified location 
in either system RAM 15 or from the location In the 
specific I/O device that has been requested. In 
decision block 75, a determination is made as to 
whether the two pieces of data are to be compared 

60 for an equal or a not equal. If an equality is required, 
then this determination is made in decision block 77 
as to whether or not the event data is equal to the 
predetermined data (mask). If an equality exists, 
then as shown in step 79, the predetermined event 

S5 has occurred and a good return code is set and the 
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operation is carried out by the system. However, if 
the answer to decision block 77 is no. then a second 
determination is made in decision block 81 as to 
whether or not a time-out flag has been set, i.e., has* 
the wait time limit expired. If the answer is yes, then 
in step 82 a time-out return code is set and the 
program requesting the wait is notified. However, if 
time-out has not occurred, then as shown in step 83 
the routine shown in Figure 6 is executed which 
stops the clock and then checks for the time limit 
expiration after the clock is restarted by an externaJ 
event (DMA or interrupt request). A similar operation 
takes place when the incoming data Is compared 
with the predetermined mask to determine if they are 
not equal. This is done in decision block 76 and a no 
here indicates that the event, i.e.. a not equal has 
occurred and a good return code is set and the 
program waiting for the event is notified of its 
occurrence. If the data in the mask are equal, which 
is not the sought after event, then the time-out flag is 
examined as was done previously. 

Note that event occurrence data may be set by an 
I/O interrupt service routine or directly by an I/O 
device itself through an I/O read or direct memory 
access. 

The flow chart of Fig. 5 explains the operation 
when the event occurrence data is compared on a 
bit by bit basis with the predetermined event which 
is being waited for. The operation of the flow chart of 
Fig. 5 is identical to the operation of the flow chart of 
Fig. 4 except that bits are being compared rather 
than an entire byte. Consequently, decision block 87 
functions the same as decision block 75 except that 
the answers depend upon whether or not the bits 
being compared are equal or not equaJ. That is, if the 
bits being compared in decision block 87 are equal, 
then decision block 89 is reached. However, if the 
bits being compared in decision block 87 are not 
equal, then decision block S3 is reached. If an 
equality is required as is by decision block 89 and it 
is achieved, then step 93 performs the same function 
as step 79. Similarly, if an inequality is required and it 
is received, then step 92 performs the same function 
as step 78. The operation of decision block 91 as well 
as steps 94 and 95 is the same as decision block 81 
and steps 82 and 83 respectively. 

The process by which sleep clock control 32 halts 
the output of system clock 33 to the non-continu- 
ously clocked devices in the system is shown in the 
flow chart of Fig. 6. Step 101 indicates that a stop 
clock command is issued to the stop clock circuitry 
within stop clock control 32. Note that if the stop 
clock circuitry has not been previously armed, or has 
been disarmed by an event already occurring, then 
no stopping of the clocking signal from output 40 will 
occur. After the sleep clock 51 has been restarted, 
i.e., sleep clock 32 has once again begun outputting 
the clocking signal over output 40 to the clocked 
devices in the system by either a DMA request or by 
an interrupt request, then decision block 102 is 
reached. As can be seen, if a t»me-out has not been 
requested, then system operation returns to deci- 
sion block 67 in Fig. 4 or 69 in Fig. 5. However, if a 
time-out has been requested, then a time-out 
counter is checked in decision block 103 as to 



whether or not it is equal to 0. If the time-out counter 
is not equal to 0, then once again system operation 
returns to decision block 67 or 69. However, if the 
time-out counter is equal to 0, then as shown in step 

5 104 a time-out flag is first set. After the time-out flag 
has been set in step 104, then system operation 
returns once again to either decision block 67 or 69. 

The flow charts of Fig. 7 and Fig. 8 explain the 
operation of the system while a program running on 

10 CPU 1 1 is waiting for a keystroke to occur or for one 
of diskette drives 26 or 27 to be accessed,* 
respectively. The flow chart of Fig. 7 details the 
operation of the system of the present invention as 
the program running on CPU 1 1 awaits a keystroke 

15 from keyboard 28. In step 1 1 1 , the running program 
invokes a wait-for-keyboard-event function by spec- 
ifying that the program wait for a compare not equal. 
That is, the keyboard buffer start is not equal to the 
keyboard buffer end, thereby signifying that key- 

20 board data has been received. This result describes 
a keyboard event. Addition-ally, no time limit is set 
for this keyboard event to occur. In step 112, the 
sleep clock control circuitry is armed but the system 
clock continues to be provided over output 40. In 

25 step 114, the start and end pointers of a keyboard 
buffer (not shown) are compared. If the start and 
end pointers are not equal, then this is an indication 
that the awaited for keyboard data has been 
received and there is no longer a need to wait for a 

30 further keyboard event. Subsequently, the keystroke 
whir.h hac Kaon entered :c prccccccd. ! lo.vaver, Y% 
the pointers are equal, then as shown in step 115. 
the system clock output over line 51 is halted by 
sleep clock control 32. Additionally, as shown in step 

35 116, the execution by CPU 11 is stopped until either 
a direct memory access request or an interrupt 
request is presented to sleep clock control 32, which 
in turn resumes the outputting of the system clock 
over output 40 to bus 51 . In step 1 17, CPU execution 

40 is resumed after the receipt of an interrupt, and in 
step 118, the scan code of the keystroke which was 
just received will be put into the keyboard buffer and 
the end pointer of the buffer will be incremented 
thereby making the start and end pointer of the 

45 buffer not equal. After the keystroke has been 
processed, step 119 indicates that execution is 
returned to the sleep routine, thereby rearming the 
sleep clock and determining that the keyboard event 
has occurred. 

50 Similarly, the operation of an application program 
running on CPU 11 is detailed in the flow chart of 
Fig. 8 while the program is accessing either of 
diskette drives 26 or 27. In step 121. the executing 
program sends commands to diskette controller 19. 

55 When the last command has been sent to diskette 
controller 19, it begins performing the required 
operation on one of diskettes 26 or 27 Independent 
of CPU 1 1 . Diskette controller 19 will notify CPU 1 1 of 
the completion of the operation or if an error occurs 

60 using an interrupt request through interrupt control- 
ler 12. In step 122. the executing program invokes a 
"wait for external event" routine and specifies a 
return operation when a diskette interrupt received 
flag has been set. When using diskette controller 19, 

65 a time-out period is set to cause the wait to be 
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aborted rf the event being waited for has not 
occurred within that time-out period. In step 123, the 
stop clock control circuitry is armed, but the system 
clock continues to be provided over output 40 to the 
non-continuously clocked devices. In decision block 5 
124. a determination is made as to whether or not a 
diskette Interrupt bit has been set If the bit has been 
set, then this Is an indication that a diskette Interrupt 
has been received by interrupt controller 12 and so " 
the "wait on external event" routine is exited in order 10 
to check to see if the diskette operation has been 
completed. 

However, if the diskette interrupt bit has not been 
set, then a signal is sent to sleep clock control 32 to 
stop outputting a clocking signal over output 40. The 15 
stopping of the clocking signal continues until either 
the next direct memory access request or until an 
interrupt request is received by CPU 11. Attendant 
with the stopping of the clocking, the execution of 
CPU 1 1 is stopped until either the DMA request or an 20 
interrupt request is received. When either of the 
above two events occurs, then the execution of CPU 
11 is resumed as shown in step 128. In step 129, a 
determination is made as to whether or not eitherof 
diskette drives 28 or 27 were the device requesting 25 
the interrupt. If so, then an interrupt handler for one 
of diskette drives 26 or 27 will set the diskette 
interrupt received bit Finally, in step 130 after the 
interrupt has been handled and processed, control 
is returned to the wait for external event routine to 30 
determine that the event has occurred th* v/oit 
luuiine is then exited. 



Claims 

1. An information processing system includ- 
ing a memory, a processor, at least one I/O 
device, and a clock for providing a clock signal 40 
to the processor, comprising: 

means for stopping the clock signal to the 
processor; 

means for detecting an interrupt generated 
by an I/O device or a request for memory * 45 
access; and, 

means for restarting a clock signal to the 
processor in response to the detection of said 
Interrupt. 

2. An information processing system accord- so 
ing to Claim 1 wherein said stopping means 
further comprises: 

means for arming the stopping means; 

means for detecting an interrupt subsequent 
to arming the stopping means and prior to 55 
stopping the clock signal; and. 

means for halting operation of said stopping 
means in response to the detection of the 
subsequent interrupt. 

3. An information processing system accord- 60 
ing to Claim 2 further comprising means for 
resetting said arming means subsequent to 
halting operation of said stopping means. 

4. An information processing system accord- 
ing to Claim 2 further comprising means for 65 



detecting a specific interrupt subsequent to 
arming the stopping means and prior to stop- 
ping the clock signal, said means halting 
operation of said stopping means only upon 
detection of said specific interrupt. 

5. An information processing system accord- 
ing to Claim 4 further comprising means for 
resetting said arming means subsequent to 
detection of said specific interrupt. 

6. An information processing system accord- 
ing to Claim 2 further comprising means for 
detecting the expiration of a predetermined 
time period subsequent to arming said stopping 
means and prior to detecting said interrupt. 

7. An information processing system accord- 
ing to Claim 6 further comprising means for 
halting operation of said information processing 
system subsequent to the expiration of said 
predetermined time period. 

8. An information processing system accord- 
ing to Claim 6 further comprising means for 
generating an error signal subsequent to the 
expiration of said predetermined time period. 

9. In an information processing system 
including a memory, a processor, at least one 
I/O device, and a clock for providing a clock 
signal to the processor, a method for controll- 
ing the operation of said clock signal, compris- 
ing: 

stopping the clock sianal to the 
upon completion of a processor operation; 

detecting an interrupt generated by an I/O 
device or a request for memory access subse- 
quent to stopping said clock signal; and, 

restarting the clock signal to the processor in 
response to the detection of said interrupt. 
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